﻿using SIIE_ERP.BaseDatos;
using SIIE_ERP.Codigo;
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.OleDb;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Shapes;

namespace Elysium.Demo.Registro
{
    /// <summary>
    /// Lógica de interacción para Window1.xaml
    /// </summary>
    public partial class WindowSeleccionRutaBD : Elysium.Controls.Window
    {
        private string _FileName;

        public WindowSeleccionRutaBD()
        {
            InitializeComponent();           
        }

        private void Button_Seleccionar_Click(object sender, RoutedEventArgs e)
        {
            Microsoft.Win32.OpenFileDialog dlg = new Microsoft.Win32.OpenFileDialog();

            dlg.DefaultExt = ".accdb";
            dlg.Filter = "accdb Files (*.accdb)|*.accdb";

            // Muestra el Open File Dialog
            Nullable<bool> result = dlg.ShowDialog();

            // Obtiene el archivo
            if (result == true)
            {   
                _FileName = dlg.FileName;
                Textbox_Ruta.Text = dlg.FileName;                
            }
            else
            {
               MessageBox.Show("Se canceló la Selección.");                
            }
        }

        private void Button_Guardar_Copy_Click(object sender, RoutedEventArgs e)
        {
            if (!String.IsNullOrEmpty(Textbox_Ruta.Text))
            {

                SrvDB.SetDatabasePath(_FileName, "config.xml");
               
               
                try
                {
                    OleDbConnection myConnection = new OleDbConnection(SrvDB.GetDefaultConnection());
                    myConnection.Open();
                    
                    OleDbCommand command = new OleDbCommand("SELECT * FROM dbo_Cat_Parametros_Sistema", myConnection);
                    OleDbDataAdapter da = new OleDbDataAdapter(command);
                    DataSet dset = new DataSet();
                    da.Fill(dset);

                    //CloseAllWindows();
                    Login.Login InfoUser = new Login.Login();
                    InfoUser.Show();
                    this.Hide();
                }
                catch (Exception ex)
                {
                    MessageBox.Show("El archivo seleccionado no es un archivo Informacion_SIEPyMEs.accdb válido." + ex.ToString());
                    return;
                }                
            }
            else
            {
                MessageBox.Show("Favor de seleccionar un archivo Informacion_SIEPyMEs.accdb.");
            }
        }

        private void CloseAllWindows()
        {
            for (int intCounter = App.Current.Windows.Count - 1; intCounter > 0; intCounter--)
                App.Current.Windows[intCounter].Close();
        }

        private void Window_Closed(object sender, EventArgs e)
        {
            Application.Current.Shutdown(0); // Cerrar definitivamente la aplicacion
        }
    }
}
